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1 INTRODUCTION 


Any user-system based on an 8 bit external bus - for example a micro- - 
processor based usersystem - can be interfaced with the MDC controller, — 
designed to simplify the 0120/D140 Disk Drive system connection. 


Adaptable to specific user systems the controller can operate as a slow 
buffered device, or as a rapid transfer device working in real time with, 
autonomous or external halt at the end of processing. 


Interfacing is simple - only 15 lines for data and control signals are re- 
quired. 


2 OPERATIONAL MODES 


Three different modes of operation have been designed into the controller, 
allowing a universal approach to different system architectures, and varied 
applications of the disk drives. These operational modes are discussed in 
detail in the following paragraphs. Throughout the remainder of the text, 
differences are noted where applicable. 


2.1 BUFFERED MODE 


For systems working with several peripheral devices, where a disk subsys- 

tem is accorded a low priority, this mode allows a slow, asynchronous 

data transfer into a memory buffer. Capacity of the buffer is 4 x 256 x 

9 bits (including a data integrity parity bit). This allows storage of up 

to 4 consecutive sectors, each sector containing a maximum of 256 data 
' bytes (1 byte = 8 bits) 


Another application of the buffered mode is updating. In this case the 
buffer is addressed and partial updating can be effected without trans- 
ferring a block of complete sectors from the disk to the processor. 


2.2 REAL TIME MODE - AUTONOMOUS HALT 


As the name suggests, data is transferred at a rate of 916 Kbytes/second 
in real time in blocks of up to four sectors. After the processor initiates 
a read/write operation the controller executes the required operation and 
automatically halts when the specified number of sectors has been proces- 
sed. 


2.3 REAL TIME MODE - EXTERNAL HALT 


This operational mode is similar to the real time mode - autonomous 

halt, with a transfer rate of 916 Kbytes/second. However, the difference 
is in that the number of sectors to be processed is not specified. After the 
processor initializes a read/write command, the controller starts execution 

of the command and continues the required operation until a halt instruc- 
tion is received from the processor. 


As a result, it is possible to read a track several times, or, write a complete 
track. 


258i s 


MDC CONTROLLER - PRODUCT DESCRIPTION 


3 INTERFACE 


The user system controller interface comprises 15 lines. These lines are 
described in detail in § 3.4 and shown schematically in figures 3 and 4. 


3.1 INTERFACE LOADING | 


Each of the 15 lines is terminated in 240 ohms to the + 5V power 
supply and 660 ohms to ground. A similar termination at the system 
end interface is recommended. Lines asserted by the Controller are dri- 
ven by an open collector driver, while lines asserted by the system in- 
terface are received by a standard TTL gate device. 


3.2 INTERFACE LOGIC 


The logic used at the interface is negative TTL. Logic levels are defined 


hereunder : 
HIGH : from 2.8 v to 5.25 volts, which corresponds to logic zero, 
or not asserted. 
LOW : from 0 v to 0.4 volts, which corresponds to logic one, or 
ground asserted, or, asserted. 
NOTE 
An asterisk following the signal name indicates that the 
Signal is significant at low level. . 
UNIDIRECTIONAL 


+5V 


USER CONTROLLER 


75451 
OR 
75452 


1 TO 5 TTL 


ol +OV CONTROLLER 


Figure 1. Interface Line loading 
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3.3 INTERFACE CONNECTOR 


Physical connection between the Controller and the user system is ensur- 
ed. by a 43 conductor flat cable. The standard CiiHB cable connector is 
shown in figure 2. Other connectors, type HEQ may also be accommoda- 
ted. | a 


Figures 3 and 4 contain the identification of each interface signal and 
the number of its connector pin. 


CiHB CONNECTOR 


+ ee 
aan 4 Pin No. 

re SIGNAL 
a——— @ | \ 

S3 ———5§ 
_ S4 ———— ¢ 
a 

S56 ee 2 
= AY esac ed 
= Si : 

Sit | 
~ $73 ' 
: $14 : 
Z | 
— ae : 
2—— 
= 
~N 
oe ae 
ae] 
oo" bomraae! 
hea 

SIGNAL GROUND 
HES TYPE CONNECTOR 
NOTE Signal/pin allocation is the same as 
VIEW ON FLAT CABLE the CiiHB connector. Pins 25 and 
ENTERING THE Cii HB CONNECTOR 26 are not connected. 


Figure 2. Interface connector 
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3.4 INTERFACE LINES 


a 


CONNECTOR PIN 


SIGNAL NAME 
RESET* 


FLAG* 
DATA* 
DOT* 


STROBE* 


D1* 
D2* 
D3* 
D4* 


D5* 


~ 


Dé* 


D7* 


D8* 


PARITY* 


GROUND 


a= LINES 


SPARE 


CONNECTOR PIN 


Figure 3. interface signals and pin Nos. - Buffered Mode 
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3.4.2 Real Time Mode interface lines 


CONNECTOR PIN SIGNAL NAME CONNECTOR PIN 


RESET* . 
FLAG* 
DATA* 
DOT* 
COMMAND STROBE* 


DATA STROBE” 


D1* 
D2* 


D3* 
D4* 
DS* 
D6* 
D7* 
pe* 


PARITY * 


GROUND 


LINES 


Figure 4. Interface signals and pin. Nos. - Real Time Mode - 
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3.5 SIGNAL LINES 


Interface lines fall into two categories - the |/O Bus (8 lines) and 5 
control lines (or 6 control lines with real time operation) - refer to the 
following paragraphs for a full detailed description. Figure 5 below, show: 
shows the interconnection between the interface lines and the controller 
buffer and registers. When the controller is operating in real time mode, 
no buffer is required. The controller interface circuits for this mode are 
shown in figure 6. 


TO USER SYSTEM TO DRIVE | 


PARITY 
DATA 
BUFFER 
8 LINES RECEIVERS 
1/0 BUS 256 x 8 bits 
. + + PARITY 
D1 - 08 
DOT 
INSTRUCTION 
DECODER 
a 7 : _ AND 
STROBE Seem | | STROBE REGISTERS - 
DECODER | 
DATA ee 


STATUS 


REGISTER 


MULTIPLEXER 


AND 
ORIVERS 


FLAG nnn t DRIVERS 
RESET RECEIVERS 


Figure 5. Buffered controller interface circuits 
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TO USER SYSTEM TO DRIVE § 


DATA STROBE —at. 


STATUS : 
REGISTER : 


PARITY 
& LINES RECEIVERS 
1/0 BUS 
D1 - 08 
INSTRUCTION 
DECODER 
AND eee eae ee 
Se eae” STROBE REGISTERS 
DECODER 

aATA = ————— ; 


MULTIPLEXER 


AND 
DRIVERS 


FLAG | DRIVERS 
RESET — . RECEIVERS 


Figure 6. Real Time controller interface circuits 
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‘3.5.1 Control Lines 


3.5.1.1 RESET* 


3.5.1.2 FLAG* 


3.5.1.3 DATA*: 


3.5.1.4 DOT* 


3.5.1.5 STROBE® or 


The RESET line is a computer interface originated, ground asserted con- 
trol. It is asserted by the computer for approximately 300 ms upon 
power up and may be asserted by the interface to unconditionally re- 
set the MDC. | 


The FLAG is an MDC originated, ground asserted control. When asserted, 
this signal informs the computer interface that the MDC requires service. 


The DATA line is a computer originated ground asserted signal. When it: 
is asserted, the 1/O lines (D1 to D8) contain a data byte. When it is not 
asserted the !/O lines will contain either a command or the controller’ 
status byte. . 


The DOT line ts a computer interface gererated, ground asserted signal. 
When asserted, it indicates that the direction of data transfer is to the 
MDC. When not asserted, the direction of data transfer is from the MDC. 


COMMAND STROBE* 


The STROBE. line is a computer interface generated, ground asserted si- 
gnal. When asserted, it indicates that information is being transferred. The 
type of information transferred depends on the operational mode : in 


buffered mode, the information is Data, Commands and Status ; in real 


time mode, only Commands or Status are transferred. This line should 


be asserted for a minimum of 0.4 and a maximum of 2.0 microseconds. 


The computer interface should not change the state of any other lines 
during the interval beginning 0.2 microseconds before assertion of STROBE 
and ending 0.2 microseconds after the release of STROBE. The release of STROBE 
is interpreted by the MDC as the completion of a transfer. 
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3.5.1.6 DATA STROBE* 


The DATA STROBE is an MDC originated ground asserted signal. When 
asserted in real time mode, it signifies that data is to be transferred to 
or from the MDC. 


3.5.1.7 PARITY* 


The PARITY is a bi-directional ground asserted line which carries the 
parity bit of the I/O Bus lines. This line is asserted if the number of 
logic ones on the I/O Bus is even. 


3.5.2 1/0 Bus : D1 - D8 


The 1/O Bus comprises 8 lines, designated as D1 to D8, with D8 as the 
least significant bit. The Bus is bi-directional and ground asserted. 


Four different types of information may be transferred over I/O Bus, 
namely, read, write, command and status modes. Each mode is accom- | 


_ panied by its own strobe and is determined by the states of the control 
lines, DATA and DOT. 


4 1/0 BUS STATES 


Lines DATA, DOT determine the command state of the I/O Bus. The 
1/O Bus has 4 states : 


- READ DATA TRANSFER 

- WRITE DATA TRANSFER 
- COMMAND CONTROL 

- READ STATUS TRANSFER 


& WN - 


The truth table given below shows the logic conditions of the DATA and 
DOT lines and the state selected. Signal STROBE or COMMAND STROBE 
must also be present. | 


Table 1. 1/O Bus Table 


| DATASTATE DOT STATE ie) BUS STATE 
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4.1 STATUS MODE 


This mode requires DATA and DOT to be unasserted and causes the 
MDC to place status information on the 1/O BUS. A strobe asserted in 
this mode is interpreted as a Read Status Strobe (RSS). 


4.2 COMMAND MODE 


This mode requires DOT asserted and DATA unasserted and causes the 
MDC to interpret the D lines as a command. D lines are examined 
only while STROBE is asserted. A strobe in this mode is interpreted as 
an Output Command Strobe (OCS). 


' 4.3 READ DATA MODE 


This mode requires DATA asserted and DOT unasserted and causes the 
MDC to place the currently held data byte on the |/O Bus. This data 
is valid in buffered mode during a data service request until the trailing 
edge of Read Data Strobe (RDS) is sensed by the MDC, and in real 
time mode during a data Strobe. 


we 


4.4 WRITE DATA MODE 


This mode requires both DATA and DOT to be asserted and causes the 
MDC to interpret the D lines as a data word to be written (D lines are - 
examined only while Write Data Strobe in buffered mode or Data Strobe 
in real time mode is asserted). 


5 COMMAND INSTRUCTIONS 


Table 2 lists all the commands that the controller will execute. 

To command the controller, the user system transfers the appropriate 
command instruction on the !/O Bus, asserts DOT and then strobes in 
with the STROBE or COMMAND STROBE line. 


To initiate a read or write operation the user system must transfer a 
command sequence of three consecutive bytes. 


Byte 1 gives the least seven significant bits of the track address where 

the operation is to start. Byte 2 identifies the two most significant bits 
of the track address and the head select. Byte 3 gives the six bit sec- 

tor address and whether the data is to be read or written. 
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In each read or write operation, three consecutive commands instructions 
are necessary. 


Command bytes 1 and 2 are reserved for track and head addressing. 
Command byte 3 contains either a WRITE or READ Command, together 
with the sector address where the operation is to be performed. 


When the controller enters the BUSY state, the read/write commands - 

- ie, command with bit D1 = zero - are non-operational until the cur- 
rent operation is terminated. All other control commands (command 
with bit D1 = One) are normally executed. 


Table 2. Subsystem command set 


1/O BUS LINES COMMAND 
D1 D2 D3 D4 DS D6 D7 D8 
TRACK SELECT - Selects track TT and prepares to 


TRACK SELECT - Selects track TT, the number of 
YF fF BH NO NI H1 Te T1 sectors NN to be chained, and head H and prepares 
| to enter the read or write mode subsequent to the 
next command. 


READ SECTOR SS - Moves on the previously selec- 


YF LH SO SI S2 S3 S4 S5. ted track and head, enters read mode, and reads data 
Starting at sector SS. 


WRITE SECTOR SS - Moves on previously selected 
SO Si S2 S3 S4 S5 track and head, enters write mode and writes re- 
ceived data starting at sector SS. 


| CLEAR DATA SERVICE - Resets the DATA SER- 
o 8 | § § 8 #8 VICE and BUSY status bits. 


1 £6 6 GF GS GF BY RESET - The controller and disk drive are uncon- 


honey reset. 
TERMINATE - this indicates the end of an opera- 
g 3 B6 B7 BS B9 BUFFER SELECT - Selects word BB in the control- 
ler buffer (lowest order bits). 
@ B2 B3 B4 B5 BUFFER SELECT - Selects word BB in the control- 
ler buffer. 
| 1 1 


BO Bi BUFFER SELECT - Selects word BB in the control- 


ler buffer (highest order bits). 
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5.1 COMMANDE BYTE No. 1 


D1 D8 
EARSESEIEIESEIES 
Nt 
ee bits 2 to 8 may be 1 or O, 


and signify the seven low or- 
der bits of the track address. 


bit D1 is always O 
5.2 COMMAND BYTE No. 2 


D1 | D8 
Sie | Ni] N2 [dD JH | To | TH 
Po —_—o 


4 bits 7,8 may be 1 or O. Us 
with bits 2-8 of command vy- 
te No.1 allow addressing up 
to 511 tracks. 


head, select : 0 = upper head 
1 = lower head 


disk indentification 


gives the number of sectors 

to be processed -i.e., up to a 

maximum of four. These bits © 
are not significant in real - time 
mode with external halt. 


always set to zero. 


5.3 COMMAND BYTE No. 3 Miva 


D1 [ D8 
RACES ESESESESES | 
,~N e” 
| . ere” bits D3-D8 give the starting sec- 


tor number where a read or write 
operation is to be performed. Bit 
D3 is the least significant bit. | 

OO : indicates a read operation 
01 : indicates a write operation 
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5.4 SUBSYSTEM INITIALIZATION 


This command is required for unconditionally resetting the MDC. The 
memory buffer is not scratched, but the buffer address painter is reset. 


Format . 
D1 


D8 
ER RARALARARARAES 
ep eect always 0 
always 1 
5.5 CLEAR DATA SERVICE 


This command is required, during an up-dating operation effected in buf- 
fered mode, to unconditionally abort a read operation in the MDC. On 
the completion of this, commands DATA SERVICE and BUSY bits are 
reset. See also updating flowchart, figure 18. 


Format : 


D1 


pinata D8 
EREARARNEArARAEA 


5.6 DATA TRANSFER COMPLETE, or TERMINATE 


This command is sent in the buffered mode of operation to inform the 
MDC that no more data transfer cycles are required by the user-system. 
It is also sent in real time mode - external halt during the last sector 

_ being read or written. in order to stop the data transfer. 


Format : 


D1 D8 
EREAEREARARALAE2 
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5.7 BUFFER MEMORY ADDRESS 


The three commands described below are used in buffered mode only 


during an updating operation in order to set the buffer memory address 
For further details, refer to the updating flowchart, figure 18. 


Byte No 1 


D1 7 D8 
1 }1{o {o | 86 | 87 | 88 {eo 


PS ee 
4 bits of buffer address - low 
order 
signifies Ist byte 


buffer address code 


Byte No 2 


D1 | D8 
i} 1] 10 | 82] 83] 84] Bs 
a et ee et el 


Lo nextt four significant bits of 
buffer address 


signifies 2nd byte 


buffer address code 


Byte No 3 


D1 , D8 
[Titi +[o To [eoy sr 


[| two most significant bits of buf- 
| fer address | 
always zero | 
third byte code 8 


buffer address code 
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6 READ OPERATION 


For a read operation, the user-system performs the 3 byte command se- 
quence described in §5. If the controller is operating in buffered mode, 
it waits for the end of the operation, indicated by assertion of the 
FLAG line, and then initiates asynchronously, X bytes transfer from the 
controller buffer (with X value of 1 to N x 256, N being the number 
of sectors to be chained). See figure 7. 


If the controller is operational in real time mode, the buffer is by- 
passed and the data is transferred directly from the disk into the user- 
system. | 


BUFFERED MODE READ SEQUENCE 


COMMAND SEEK SEARCH SECTOR READ BUFFER END OF DATA 
SEQUENCE MOVEMENT AND READ CYCLE TRANSFER 


1} 


BUSY 


FLAG | 
LOAD BUFFER 


mee @eeoee 


Figure 7. Read operation - buffered mode 


REAL TIME MODE - READ SEQUENCE 


ae OAL 


ST 1 ST 256 

DATA ST 2 

STROBE onal | 
feces. teaieteee ees. ee 
COMMAND HEAD POSITIONING, STROBE DATA IN 
SEQUENCE SEARCH SECTOR PROCESSOR 


Figure 8. Read operation - real time mode 
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7’ WRITE OPERATION 


For a write operation, the user system first performs the 3 byte com- 
mand sequence, as in the read operation and next initiates (asynchro- 
nously, if-the MDC is operating in buffered mode) an. X bytes transfer 
into the Data Buffer, (with X = value of 1 to N x 256 ; N being the 
number of sectors to be chained) and then indicates the end of trans- ° 
fer with a TERMINATE command. If less than N x 256 bytes are 
transferred into the Data Buffer the remaining data field will be zero 
filled (see figures 9 and 10). 


After the FLAG line assertion indicating the end of operation, the user- 
system must read the Status Register to check that no error occurred 
in the disk sub-system during the operation. Refer to section 8 for’ 
Status Register description. If the MDC is operating in real time mode, 
then the data is transferred synchronously with DATA STROBE to the 
MDC. See figure 11. 


000 


255 


S511 DATA ZONE (filled by processor) 


767 


} ZERO. ZONE (filled by controller) 
1023 


Figure 9. Data buffer 


BUFFERED MODE WRITE SEQUENCE 


COMMAND BUFFER LOADING, END OF DATA END OF HEAD SEARCH SECTOR, 
SEQUENCE START SEEK TRANSFER POSITIONING WRITE DATA 


enema ARDEA ADS EL TILOS TEE LATEST LIS 


| 


LOAD BUFFER 


Figure 10. Write operation - Buffered mode 
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REAL TIME MODE WRITE SEQUENCE 


a ZT: EE WZ 


BUS 
ST 1 ST 2 1 26 00C~* 
DATA : 
STROBE 
COMMAND HEAD POSITIONING, | 
SEQUENCE SEARCH SECTOR STROBE DATA INTO 
CONTROLLER | 


Figure 11. Write operation - real time mode 


8 STATUS READ OPERATION 


The status of the subsystem can be read (sampled) at any time by the 
external control unit by monitoring the DATA and DOT lines. However, 
in order to properly reset the status lines that are transient, the compu- 
ter interface will usually pulse. the strobe line after or during the samp- 
ling operation, generating an RSS. ( = DATA, DOT unasserted,followed 
by strobe). 


lf the Write Count Error, the Fault Status, the Parity Error Status or 

the Read Error Status lines -are set, they will be reset on the trailing 

edge of the Read Status Strobe pulse ; if one of the error bits is set 

after the leading edge of a RSS strobe, it will only be reset by the 

next RSS strobe in order to allow proper sampling operation. Figure 12 
- shows the recommended timing of a status transfer. 


8.1 STATUS REGISTER 


The status register is used to store information comming from the disk 
subsystem. This information comprises three functional bits giving the 
operational status of the disk subsystem and five incident bits indicating 
fault conditions. . | 


bits D1 D8 
ast [woe [ Fut | rem [ren] soy] nov | ons 
fault conditions operational states 


The eight bits are described in detail in § 8.2 


246% 


MDC CONTROLLER - PRODUCT DESCRIPTION 


Table 3. Status Register bits 


[ast [woe | eur] ven [nen | ev [ov | ons 


= Data service 


Disk is ready to seek, 
read or write 


MDC is busy 

Read error 

Parity a 

Disk subsystem erri 


Write count error 


Bad sector found 


ERROR / 

Wy Wy STATUS a STATUS 

ses 4 yy Ui, VALID as A _ VALID Yyy 
y Lify MY (MAY CHANGE ) OFSeT & (MAY CHANGE) 17//// 


! ” i 
| Y | OY 


DATA* YG ; “UV, j | YY, 
se //////17 7 ZZ 


X 2 200 ns; YS 400 ns 


- 


Figure Status transfer timing. 


(*) BITS D2, D3, 04 and 05 of the status byte.- and bit Dl, See § 8.2.1, 


Figure 12. Status transfer timing 
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8.2 STATUS BITS 


8.2.1 BSF - Bad Sector Found 


Bad Sector status, bit D1, indicates that at least one sector which has 

been processed by the MDC is found defective. As a result, the opera- 
tion is aborted and the flag line is asserted in the case where the MDC 
does not process a bad sector saving operation. Refer to table 4. 


Table 4. BSF status 


OPERATIONAL MDC HANDLES FLAG LINE ABORT 
MODE SAVING OPERATION - ASSERTED OPERATION 


BUFFERED YES 
Bad sector status may be 
permanently set to logic 
zero | 


REAL TIME YES 
INTERNAL Bad sector status may be 
HALT permanently set to logic 
zero 


REAL TIME 
EXTERNAL 
HALT 


NOTE 


The BSF status is cleared by an RSS, by dispatching 
a reset command, or by asserting the RESET LINE. 


8.2.2 WCE - WRITE COUNT ERROR 


Write count status is set in buffered mode if more than N x 256 bytes (N being 
the number of sectors to be chained) are issued to the buffer and is 
indicated by the assertion of D2. This status is cleared by a Read Sta- 
tus Strobe pulse, by sending a Reset command or by asserting the re- 
set line. This bit is always set to logic zero in the real time operational 
mode. | 


- 91 


8.2.3 FLT - Fault 


8.2.4 PER - Parity Error 
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Fault status is indicated by the assertion of D3 and is set under the 
following conditions : 


e A failure of the disk to complete a search operation within approxi- 
mately 500 milliseconds. 


e A failure of the MDC to detect a sector pulse within 500 microse- 
conds. 


e A failure of the MDC to complete a read/write operation on the 
addressed sector within the period between two index pulses. 


e A failure of the MDC to detect a proper device clock signal. 
e A failure in the disk drive. 


Fault status is cleared by RSS, by issuing a reset command or by asser- 
ting the RESET line. 


% 


cy 


Parity error status is indicated by the assertion of D4 and is set in the 
case of : 


e A failure to match the parity bit of the addressed sector written on 
the track recognition area of this sector and the parity bit of the 
track sector calculated in the MDC. This error may occur during a 
read/write operation. | 


e A failure of the MDC to match the parity bit of a data byte written in the buf- 
fer and the parity bit of this data byte when read out of the buffer. This error 
may occur during a data transfer operation from the MDC buffer tc 
computer when in read mode and during a write operation into the uisk 
when in write mode. 


e A failure of the MDC to match the parity line and the parity of the 
8 bidirectional lines during an output command strobe, a write data 
strobe in buffered mode or a data strobe in real time mode write 
operations. 


Parity error status is cleared by RSS, by sending a Reset command, or 


by asserting the Reset line. 
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8.2.5 RER - Read Error 


Read error status is indicated by the assertion of D5 and is set : 


@e When the data syncfield is not detected correctly 


@ When the MDC had read and transferred a block of data and then 
finds that the Cyclic Redundancy Check characters at the end of the 
block do not agree with what it has calculated. 


Read error status is cleared by a read status strobe pulse, by sending a 
Reset command, or by asserting the Reset line. 


8.2.6 BSY - Busy 


Busy status is indicated by the assertion of D6 whenever the Midi Disk 
Controller is in the Read or Write mode. : 


8.2./ RDY - Ready 


Ready status is indicated by the assertion of D7 whenever a disk is in 
the drive, the door is closed, the disk is spinning at the specified rate 
and the heads have been positioned over a track. The Midi Disk Control- 
ler will delay a read/write operation until the Ready line is true. 


8.2.8 DAS - Data Service 


The Data Service request is indicated by the assertion of D8 in buffered 
mode and occurs whenever data should be transferred. This line is clear- 
ed by the positive-going edge of either a Read Data Strobe pulse or 
a Write Data Strobe pulse depending on whether the system is reading 
or writing, and by a Clear Data Service Command. This bit is always 
set to logic zero with the controller in real time mode of operation. 


8.3 FLAG LINE 
The flag line is true when one of the following conditions exist : 


1. The Data Service status bit in buffered mode is true, indicating that 
data is ready to be transferred in either a read or write operation. 
Appropriate transfer of data (as signaled by a Write Data Strobe pulse 
or Read Data Strobe pulse) resets the Data Service bit. 


2. An error condition exists, caused by the rise of Bad Sector Found | 
(if any), Write Count Error, Fault, Parity Error or Read Error. The | 
assertion of the Flag line will allow the computer to fall through its 
data transfer. 


3. The busy line drops after a Terminate command is issued (while the 
system is in either the buffered read or write mode), and raises the 
computer/controller Flag line. The raising of this line signals to the 
external control unit that the MDC has completed writing the data 
in write mode or sensed an end of data buffer reading operation in 
Read mode. 
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The Flag line is reset by generating a Read Status Strobe, issuing a Re- 
set command or pulsing the Computer/Controller Reset line. 


9 DATA TRANSFER 
9.1 BUFFERED MODE 


The controller is said to be buffered because it includes a data buffer 
with a capacity of four sectors. 


When the system is in the Read mode, data is transferred from the 
disk to the buffer and then to the external control unit at any rate 
established by the external control unit ; the buffer might be read 
more than once by the CPU before a terminate command is issued. 


When the system is in Write mode, the external control unit transf« 
data to the buffer at any rate it desires. When the MDC receives a ter- 
minate command (the buffer is full), it automatically transfers the data 
into thedisk. __ 


To end a write operation, the Terminate command is issued. When the 
subsystem receives this command, it immediately lowers the FLAG line 
and, if less than a full sector was transferred, fills out the sector with 
zero bytes and writes the CRC characters. 


Finally, it causes the FLAG line to go high to signal the completion of 
the write operation. 


DATA SERVICE (bit 08) 


PARITY 


in Zs WA Os WHY 
| = > ae 2 See 


NOTE : X © MOC processing time : 0.9 us < X < 1.9 ws. 


S$ « service time with no timing restrictions. External control 
may leave the flag unserviced indefinitely. 


Figure 13 . Data transfer timing - Buffered mode 
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Figure 13 illustrates the data transfer requirements. One byte is transfer- 
red at a time, where the external control unit is not required to res- 
pond within a specific time interval after the Flag goes true. Thus the 
external control unit can treat the system as a truly asynchronous de- 
vice. However, if the Read Data Strobe/Write Data Strobe frequency is 
fast enough, the buffer can be written or read with a maximum trans- 
fer rate of 916 Kbytes/second. 


9.2 REAL TIME MODES 


Data transfer is synchronous with the disk and each data block consists 
of 256 bytes. Figure 14 gives the detailed timing for each byte ex- 
change during read or write operations. 


READ MODE 


DATA —— "4 | | TT 


WRITE MODE 


T/O BUS 


2100 ns 


DATA a: [ne wee 


T = DISK ORIVE CLOCK PERIOD : 136 nsec. + 3% 


2100 ns 


Figure 14. Data transfer Timing - Real Time Mode 
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10 SECTOR FORMAT 


There are 392 tracks on each disk face with each track containing 48 
sectors in which data is formatted in blocks of ee bytes. 


Data integrity is ensured by a longitudinal solvnonmial (x16 + xt + x2 +1) 
used for cyclic redundancy checking (at the system interface level and 

in the buffer memory, data is checked by means of a lateral parity 

bit) 


Figure 15 illustrates the format for each sector. 


GAP DATA SYNC. DATA POSTAMBLE 


10 bytes 1 byte 256 bytes 1 byte 
0's FD16 - - FF16 


Figure 15. Sector format 


11 BAD SECTOR PROCESSING ~ 


A disk cartridge is not defect-free ; consequently, the data blocks must 
not be recorded in the defective, or bad, sectors. Bad sectors are indic- 
ated at the device interface level by an appropriate signal. 


The system will be responsible for bad sector saving and management 
of the, retrieval operation. The MDC allows several possibilities of man- 
agement, outlined below. 


‘11.1 BAD SECTOR MANAGEMENT - BUFFERED MODE 
Bad sector management is processed completely by the MDC (2 spare 
sectors are provided at the end of each track), and the user system 


ignores the disk defects. 


The Bad Sector Found status bit (BSF) may however be set by the 
MDC and used for logging purposes by the system. 
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11.2 BAD SECTOR MANAGEMENT - REAL TIME MODES 


In these modes of operation, bad sector management may be either 
processed by the MDC or taken over by the user system. 


e MDC Management 


- Each defective sector is saved in the immediate following sector. In this 
case, the MDC must wait for an INDEX pulse prior to beginning a 
read/write operation, giving a read/write latency time of 8.33 msec 
(half disk revolution). 


The Bad Sector Found (BSF) status bit may, however be set by the 
MDC and used for system logging. 


e System Management 


In this case, when the MDC detects a defective sector it immediately 
aborts the current read/write operation. It then asserts the Flag line to 
allow the system to stop the data transfer and sets the BSF status bit. 
The system then initiates its own save operation. The total number of 
sectors available is 50 per track (with a maximum number of two 
being defective). 


12 READ/WRITE OPERATION FLOWCHARTS 


Figure 16 illustrates a typical operation sequence in buffered mode. 
Note, there are no timing restrictions and that it is not necessary to 
_ wait for a valid CRC error status at the end of a read transfer. Figure 
17 illustrates a typical operational sequence in real time modes. If an 
error occurs, the FLAG line remains asserted until the corresponding 
error status Is reset. 


13 SECTOR UPDATING OPERATION FLOWCHART 


To update the data content of N sectors (with N < 4) the user sys- | [ 
tem issues a read command sequence (three commands), waits for the | 
FLAG line to go high and resets it with the CLEAR DATA SERVICE | 
command. : 


Next, the user system dispatches a write command sequence, waits for 
the FLAG line and then sends the three command sequence for buffer 
addressing. This selects the starting buffer word and initiates “X” num- 
ber of transfers to the buffer (X words updated, with X as value, from 
1 to 256). Finally, the computer sends the Terminate command, waits 
for the assertion of the FLAG line and checks if the operation was 

- done correctly. A flowchart illustrating an updating operation is shown 
in figure 18. 
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Figure 16. Read/write operation flowchart - buffered mode 
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Figure 18. Sector updating flowchart - buffered mode 
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